# MIGRATING FROM 8/16-BIT TO 32-BIT ARM MICROCONTROLLER





## Introduction

### Purpose

To Provide Information Outlining Migration From 8-Bit/16-Bit Microcontroller To A 32-Bit ARM Platform.

### Objectives

- 01 Compare traditional 8/16bit cores to ARM
- 02 Provides and overview of ARM7 architecture.

03 Discuss the similarities between8-bit/16-bit and ARM MCUs



# Expert 10

# **ARM Archicture**

- 01 The STM32F4 Is Based On Armv7e-M Architecture.
- **02** 3-Stage Pipeline With Branch Speculation.

### 03. Instruction Set

Ĭ

Thumb-1

- ii Thumb-2
- iii 32-Bit Hardware Intergern Multiply With 32-Bit Or 64-Bit Results, Signed Or Unsigned.
- iv 32-Bit Hardware Integer Divider (2-12 Cycles).
- <sup>04</sup> 1 to 240 interrupts, plus NMI (Non-maskable Interrupt).
- 05 12 Cycle Interrupt latency.
- **06** Integrated sleep modes.

### **3-Stage Instruction Pipeline**





# **Optimal Pipeline**

In this example it takes 6 clock cycles to execute 6 instructions. All operations are in registers ( single cycle instructions ). Clock cycles per instruction (CPI)=1



# **Branch Pipeline Example**

- Branches break the pipeline
- Example in ARM state



# Typical 8/16 Bit Vs ARM

### 8/16-bit (CISC)

No Instruction pipeline.

One operating mode.

Single Instruction Type.

Simpler register organization.

### ARM (RISC)

Instruction pipeline: ARM7-> 3stage ARM9 -> 5 stage ARM11-> 9 stages

Multiple operating mode: User, FIQ, IRQ, Supervisor, Abort, Undef and System.

Multiple Instruction types: ARM and Thumb mode.

More sophisticated register organization with shadow registers for various modes.

# **ARM Processor Modes**

ARM has seven operating modes



User: unprivileged mode under which most applications run.

ii FIR: entered, when a high priority (fast) interrupt.



IRQ: general purpose interrupt handling.





System: prevailed mode using same registers as user mode.



Abort: used to handle memory access violations.



Undefined: used to handle undefined functions.

Many 8/16-bit processors don't implement different modes of operation

# **ARM Instruction Set**

- All instruction are 32-bit long.
- Many instructions execute in single cycle.
- Most of the ARM instruction can be conditionally executed.
- Ould be divided into six broad classes of instruction:
  - i Branch instructions.
  - ii Data processing Instructions.
  - iii Status register transfer instructions.
  - iv Load and Store instructions.
  - v Coprocessor instructions.
  - vi Exception-generating instructions.

## **ARM7 Assembly**



# Thumb State

- ARM uses a 32-bit architecture with a subset of 16-bit instructions, still using 32-bit data and registers.
- <sup>02</sup> Set of instructions re-coded into 16-bits.
  - Improve code desity by ~30%.
  - Saveing program memory space.
- <sup>03</sup> In Thumb state only the program code is 16-bit wide.
  - After fetching the 16-bit instruction from memory, they are decompressed to 32-bit instruction before they are decoded and executed.
  - All operation are still 32-bit operation.

# Expert 10



# **ARM Thumb Instruction Set**

### ARITHMETIC

-Add : ADD, ADC (low/high, immediate, to SP, w/ carry)

-Subtract : SUB, SBC (Immediate W/Carry)

-Negate : NEG

-Multiply :MUL

-Compare : CMP, CMN (low/ high, immediate, negative)

<>

### BRANCHING

-Branch (unconditional) : B -Branch and Exchange : BX -Branch with Link : BL -Conditional (14 variants) PUSH (PUSH) Registers onto stack (LR, too)

POP (POP) Registers from stack (PC, too)



 $\bigcirc$ 

Bit clear : BIC

SOFTWARE INTERRUPT(SWI)

 $\sim$ 

### MOVE

### MOV, MVN

- Immediate
- -Low/ High
- Move Not



### LOAD\*/STORE

Word (immediate/register offset)

- Byte (signed\*, immediate/ register offset)
- Halfword (signed\*/immediate register offset)
  - Conditional (14 variants) Multiple

Relative (PC\* or SP)

Address\* (using PC or SP)

### SHIFT

### LSL, LSR, ASR

Left/Right Arithmetic/right

### Rotate(ROR)

ł

Right

# **Registers In Thumb State**

The thumb state register set is a subset of the ARM state set. The programmer has direct access to :-



In thumb state, the higher registers (r8-r12) are not part of the standard register set.
The assembly language

programmer has limited access to them, but can use them for fast temporary

# Interrupt Handler Consideration

### 8/16-BIT (CISC)

- Normally, only one interrupt "type"
- Limited or no interrupt priorization
- No change in code type to service ISRs

### ARM (RISC)

- -Three types of interrupt
  - Fast Interrupt
  - Interrupt Request
  - Non-Vectored Interrupt
- -Detailed control over priority.
  - FIQ always executed first
  - IRQ priority levels (0-15)
  - Default interrupts lowest priority

-Interrupt Service Routines must be written in ARM mode.

# Vectored Interrupt Controll

- 01 ARM Processor.
- <sup>02</sup> 32 interrupts request inputs.
- <sup>03</sup> 16 IRQ interrupt can be auto-vectored.
- <sup>04</sup> Single instruction vectoring to ISR.
- Dynamic software priority assignment.
- <sup>06</sup> 16 Non-vectored interrupts.
- 07 Software Interrupts.
- <sup>08</sup> FIQ- Fast interrupt.

# VIC-FIQ (Fast Interrupt) Details

- <sup>01</sup> FIQ have higher priority than IRQs
  - Service first
  - ii FIQs disable IRQ
- <sup>02</sup> FIQ vector is last vector table (Allow handler to run sequentially from that address).
- <sup>03</sup> FIQ mode has 5 extra banked registers r8-r12 (interrupt must always preserve non-banked registers).

# Is It Time To Move To ARM?

01

Small 48-pin and 64-pin QFN packages available.

- <sup>02</sup> Prices competitive with 8 or 16-bit architectures.
- Low cost development tools are available.













### **Microcontroller Users Want**

### 01

Many customers are using **8/16-bit** device today want :

- Easy upgrade path with minimal relearning.
- ii Single chip solution:
  - On chip flash
  - Timers, PWM, UART, SPI, I2C
  - ADC
  - Predicable, deterministic performance
  - No cache
  - Same performance between flash and memory
- Low power for battery operated devices.
- 03 Fast IO.
- <sup>04</sup> High performance, good quality and high reliable flash memory.
- Hence, ARM is suitable choice in those scenarios.

# Typical 8/16 Bit Vs ARM

| Parameters          |  |
|---------------------|--|
|                     |  |
| GPIO                |  |
| U(S)ART             |  |
| SPI                 |  |
| I2C                 |  |
| 16-bit timer        |  |
| ADC                 |  |
| RTC                 |  |
| Maximum Clock speed |  |
| PWM                 |  |

| ATMEGA328p  | STM32F103C8T6 |
|-------------|---------------|
|             |               |
| 23          | 37            |
| 1           | 3             |
|             | 2             |
| 1           | 2             |
|             | 3             |
| 18-channels | 2-9 Channels  |
| 0           |               |
| 20MHZ       | 72MHz         |
| 6           | 16            |
|             |               |



This report is brought to you by EmbeddedExpertIO. EmbeddedExpertIO is an online embedded systems school focused on professional embedded systems software programming.

If you are new to embedded systems programming our community provides step-by-step courses that will take you from "blinky" to "build your own Rtos".

If you are an embedded systems developer who wants to specialize in some specific aspect of embedded systems programming, We also provide a wide range of specialization courses to help you master different aspects of embedded firmware development.

We look forward to welcoming you to EmbeddedExpertIO.

Visit us at : https://study.embeddedexpert.io/

## Thank You

